import { Meta } from '@storybook/blocks';

import * as ClipPathStories from '../stories/ClipPath.stories';

<Meta of={ClipPathStories} />

# ClipPath

A widget that clips its child using a path.

## Example


```dart liveslice=ClipPath

String _imageUrl = 'https://images.unsplash.com/photo-1565898835704-3d6be4a2c98c?fit=crop&w=600&q=60';

ClipPath(
  clipper: ArcClipper(),
  child: SizedBox(
    width: 320,
    height: 240,
    child: Image.network(_imageUrl, fit: BoxFit.cover,),
  ),
)
// ....

class ArcClipper extends CustomClipper<Path> {
  @override
  Path getClip(Size size) {
    var path = Path();
    path.lineTo(0.0, size.height - 30);

    var firstControlPoint = Offset(size.width / 4, size.height);
    var firstPoint = Offset(size.width / 2, size.height);
    path.quadraticBezierTo(firstControlPoint.dx, firstControlPoint.dy,
        firstPoint.dx, firstPoint.dy);

    var secondControlPoint = Offset(size.width - (size.width / 4), size.height);
    var secondPoint = Offset(size.width, size.height - 30);
    path.quadraticBezierTo(secondControlPoint.dx, secondControlPoint.dy,
        secondPoint.dx, secondPoint.dy);

    path.lineTo(size.width, 0.0);
    path.close();

    return path;
  }

  @override
  bool shouldReclip(CustomClipper<Path> oldClipper) => false;
}
```

## Related Links

- https://api.flutter.dev/flutter/widgets/ClipPath-class.html
